﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Linq;
using QuanLyDaiLy.Model;
using System.Data.OleDb;

namespace QuanLyDaiLy.Context
{
    public class CPhieuThuContext : DataContext, IContext<CPhieuThu>
    {
        #region Variable
        Table<CPhieuThu> table;
        #endregion

        #region Constructor
        public CPhieuThuContext(OleDbConnection connection)
            : base(connection)
        {
            table = GetTable<CPhieuThu>();
        }
        #endregion

        #region Public Method
        /// <summary>
        /// Thêm vào phiếu thu mới
        /// </summary>
        /// <param name="obj">Phiếu thu được thêm vào</param>
        public void Them(CPhieuThu obj)
        {
            table.InsertOnSubmit(obj);
            this.SubmitChanges();
        }

        /// <summary>
        /// Cập nhật phiếu thu và Database
        /// </summary>
        /// <param name="obj">Phiếu thu đã được cập nhật</param>
        public void CapNhat(CPhieuThu obj)
        {
            var phieuthu = LayThongTin(obj.MaPhieuThu);

            phieuthu.Initialize(obj.MaDaiLy, obj.SoTienThu, obj.NgayThuTien);
            this.SubmitChanges();
        }
        
        /// <summary>
        /// Xóa phiếu thu ra khỏi Database
        /// </summary>
        /// <param name="maso">MaPhieuThu cần xóa</param>
        public void Xoa(ulong maso)
        {
            var phieuthu = LayThongTin(maso);

            table.DeleteOnSubmit(phieuthu);
            this.SubmitChanges();
        }

        /// <summary>
        /// Lấy thống tin phiếu thu
        /// </summary>
        /// <param name="maso">MaPhieuThu cần lấy thông tin</param>
        /// <returns>Phiếu thu</returns>
        public CPhieuThu LayThongTin(ulong maso)
        {
            var query = from e in table where e.MaPhieuThu == maso select e;

            return query.First();
        }

        /// <summary>
        /// Lấy toàn bộ phiếu thu
        /// </summary>
        /// <returns>Danh sách phiếu thu</returns>
        public List<CPhieuThu> LayDanhSachTatCa()
        {
            var query = from e in table select e;

            return query.ToList();
        }
        #endregion 
    }
}
